草庐IT

c++ - static_cast 安全

全部标签

c++ - 如何检测文件是否被Windows中的其他进程打开

我在Windows中使用_findfirst函数打开文件,但我只想打开其他进程未打开的文件。情况是我将扫描目录读取文件并删除它们,而其他进程会在其中创建新文件。为了避免竞争条件,我发现了这个question其中提到可以使用nosharing选项打开文件。但这是怎么做到的?更新:我无法控制写入过程,所以不知道在创建文件时使用了哪些标志(如果没有)。此外,写入过程可能会发生变化(第三方软件)。 最佳答案 假设您的2个进程是唯一将打开文件的进程,从MSDNopensample:hFile=CreateFile(argv[1],//name

c++ - 如何在 Windows 上预留内存并将以后的映射文件放入其中?

我想保留一个内存区域,然后将映射文件连续地放入保留的内存中。映射文件之间可能存在较大的时间间隔,在此期间其他函数可能会从堆中分配内存。映射后,文件可能无法取消映射并映射到新的内存位置。在Linux上会是这样的:#include#include#include#include#includeintmain(){void*memory=mmap(nullptr,getpagesize()*2,PROT_READ|PROT_WRITE,MAP_ANONYMOUS|MAP_PRIVATE|MAP_NORESERVE,-1,0);//reservememoryinthandle1=::open(

c - C 中的 ISO 8601 周数

我正在尝试使用C获取ISO8601周数。我的PC上安装了MinGW。GCC版本是5.3.0。你可以在下面看到我的代码。strftime不适用于说明符“%V”。但它适用于说明符“%W”。但这不是我想要的。我需要ISO8601格式的年份周数。我已经用2个不同的在线C编译器测试了我的代码,它们都运行良好。我怀疑我电脑上的编译器没有配置好。谁能告诉我我做错了什么?任何帮助将不胜感激。这是我的代码:#include#include#includeintmain(){time_ttimep;structtm*time_inf;charbuff[80];time(&timep);time_inf=l

c++ - IUnknown 中的 addref 和 release,它们实际上是做什么的?

我一直在努力思考Windows中的shell扩展。需要实现的一些函数是addref()和release()。它说,它会跟踪对象引用并在不使用时释放它们。简单解释一下,它实际跟踪的是什么?在我看来,你创建自己的对象,根据你的目的实现各种接口(interface),然后让classfactory将对象返回给com引擎运行,除非我弄错了。我对这个概念的理解真的很慢。也是一步一步的过程,windowscom引擎加载shell扩展,从识别dll到实际执行到卸载。请做一些简单的解释。问候 最佳答案 Shell扩展只是普通的COM对象。接口(in

c++ - 假定 Windows 伪句柄的值是否安全/已定义?

我正在为Windows编写一段C++代码,需要查询进程及其每个单独线程的计时。为了进行必要的系统调用,我需要进程及其每个线程的句柄。我正在使用getCurrentProcess和getCurrentThread函数,它们都返回一个伪句柄。经过进一步检查,我注意到所有线程的伪句柄共享相同的值。在互联网上简单搜索后,我发现以下文章报告了与我得到的进程和线程伪句柄相同的值:https://weseetips.wordpress.com/2008/03/26/getcurrentthread-returns-pseudo-handle-not-the-real-handle/我的问题:从一个线

c - 为什么 getsockopt 返回错误?

我遇到了Windows上套接字的问题。调用getsockopt()总是失败。奇怪的是setsockopt()似乎有效(至少它报告成功......虽然我设置的选项似乎没有我预期的效果)。我的代码如下。运行它会报告成功的setsockopt调用,但getsockopt失败并返回WSAEFAULT。我做错了什么?structlingerling;...ling.l_onoff=1;ling.l_linger=10;if(setsockopt(sock,SOL_SOCKET,SO_LINGER,&ling,sizeof(ling))==SOCKET_ERROR){fprintf(stderr,

c++ - 默认安全描述符

我的应用程序有2个进程,一个需要提升,另一个不需要,但是它们在同一桌面上的同一用户帐户下运行。我需要在从文件读取的提升进程中创建一个文件(不在磁盘上,其他类型的文件),但让我的非提升进程对该文件具有写访问权限。使用nullptrSECURITY_ATTRIBUTES,非提升进程无法打开文件,CreateFile失败并显示拒绝访问代码。这是预期的,SetSecurityDescriptorDacl解决方法类似于thisanswer工作正常。但是,我不喜欢这种解决方法。我不想将对该文件的写入权限授予所有人。我只想授予当前用户访问权限。这有点敏感,提升的读取器进程将运行数小时,我不希望每个人

c - Windows线程接受套接字上的连接

我熟悉pthreads,但不熟悉Windows线程。在Linux中,一个新线程可以这样启动:pthread_ttid;intrc=pthread_create(&tid,NULL,Threadfn,&newsocket);assert(rc==0);////和Threadfn可以轻松重构Socket:void*Threadfn(void*vargp){pthread_detach(pthread_self());int*Socket=(int*)vargp;print("Socketis%d\n",*Socket);//recv/read/sendetc..pthread_exit(N

.NET 3.5 安全问题

我在windows2003系统上安装了.net3.5。我注意到除了最新的.net3.5级别之外,还会自动安装以前的.net级别,例如1.0和2.0。这些旧版本存在安全问题,我认为这些问题已在.net3.5中得到纠正。这是正确的还是必须为这些旧的.net版本安装相关的安全补丁来加固系统?谢谢 最佳答案 .Net3.5SP1包含自为.Net2.0、3.0和3.5打包之日起所有汇总的安全补丁。.Net3.5与3.0一样,是.Net2.0的超集。这意味着它基本上是.Net2.0的附加组件。 关于

c - c中的ftruncate trunc文件找不到这个函数

我想截断文件,比如setsizeof()和FILE*我正在开发vs2003windows#includethere'snosuchlib我该怎么做freopen()会截断所有vut未写入的数据-出现EINVAL错误一些帮助?????? 最佳答案 _chsize函数做得更好,它让fdans大小更改为 关于c-c中的ftruncatetrunc文件找不到这个函数,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c